#include <iostream>
#include <queue>
#include <map>
#include <unordered_map>
#include <vector>
#include <algorithm>
#include <cmath>
#include <string>
#include <cstring>
#include <set>
#include <unordered_set>
using namespace std;
typedef long long ll;
typedef unsigned long long Ull;
typedef pair<int,int> PII;
const int N=2e6+10;
int a[N];
int q[N];
int main()
{
	ios::sync_with_stdio(0);
    cin.tie(0);
	int n,m;
	cin>>n>>m;
	for(int i=0;i<n;i++)
	{
		cin>>a[i];
	}
	cout<<0<<'\n';
	int head=0;
	int tail=0;
	q[head]=0;
	for(int i=1;i<n;i++)
	{
		if(q[head]==i-m-1)
		{
			head++;
        }
		cout<<a[q[head]]<<'\n';
		while(head<=tail && a[q[tail]]>=a[i]) 
        {
            tail--;
        }
        q[++tail]=i;
	}

	return 0;
}

